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GSM identities. These should be interpreted as being references to the corresponding ETSI deliverables. 
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Foreword 



rd , 



This Technical Specification has been produced by the 3 Generation Partnership Project (3GPP). 

The contents of the present document are subject to continuing work within the TSG and may change following formal 
TSG approval. Should the TSG modify the contents of the present document, it will be re-released by the TSG with an 
identifying change of release date and an increase in version number as follows: 

Version x.y.z 

where: 

X the first digit: 

1 presented to TSG for information; 

2 presented to TSG for approval; 

3 or greater indicates TSG approved document under change control. 

y the second digit is incremented for all changes of substance, i.e. technical enhancements, corrections, 
updates, etc. 

z the third digit is incremented when editorial only changes have been incorporated in the document. 



Introduction 



rd , 



The present document is part of a TS-family covering the 3 Generation Partnership Project: Technical Specification 
Group Services and System Aspects; Telecommunication management; as identified below: 

32.601: "Configuration Management (CM); Basic CM Integration Reference Point (IRP); Requirements" 

32.602: "Configuration Management (CM); Basic CM Integration Reference Point (IRP): Information 

Service (IS)" 

32.603: "Configuration Management (CM); Basic CM Integration Reference Point (IRP): Common 

Object Request Broker Architecture (CORBA) Solution Set (SS)" 

32.607: "Configuration Management (CM); Basic CM Integration Reference Point (IRP): Simple Object 

Access Protocol (SOAP) Solution Set (SS)" 

Configuration Management (CM), in general, provides the operator with the ability to assure correct and effective 
operation of the 3G network as it evolves. CM actions have the objective to control and monitor the actual configuration 
on the Network Elements (NEs) and Network Resources (NRs), and they may be initiated by the operator or by 
functions in the Operations Systems (OSs) or NEs. 

CM actions may be requested as part of an implementation programme (e.g. additions and deletions), as part of an 
optimisation programme (e.g. modifications), and to maintain the overall Quality of Service (QoS). The CM actions are 
initiated either as single actions on single NEs of the 3G network, or as part of a complex procedure involving actions 
on many resources/objects in one or several NEs. 
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Scope 



The purpose of this Basic Configuration Management (CM) IRP: CORBA Solution Set is to define the mapping of the 
Basic CM IRP: IS (see 3GPP TS 32.602 [4]) to the protocol specific details necessary for implementation of this IRP in 
a CORBA/IDL environment. 

This document defines NRM independent data types and methods. 

This Solution Set specification is related to 3G TS 32.602 V7.0.X. 



References 



The following documents contain provisions which, through reference in this text, constitute provisions of the present 
document. 

• References are either specific (identified by date of publication, edition number, version number, etc.) or 
non-specific. 

• For a specific reference, subsequent revisions do not apply. 

• For a non-specific reference, the latest version applies. In the case of a reference to a 3GPP document (including 
a GSM document), a non-specific reference implicitly refers to the latest version of that document in the same 
Release as the present document. 

[I] 3GPP TS 32.101: "Telecommunication management; Principles and high level requirements". 

[2] 3GPP TS 32.102: "Telecommunication management; Architecture". 

[3] 3GPP TS 32.600: "Telecommunication management; Configuration Management (CM); Concept 

and high-level requirements". 

[4] 3GPP TS 32.602: "Telecommunication management; Configuration Management (CM); Basic CM 

Integration Reference Point (IRP) Information Service (IS)". 

[5] 3GPP TS 32.300: "Telecommunication management; Configuration Management (CM); Name 

convention for Managed Objects". 

[6] OMG Notification Service, Version 1 .0. 

[7] OMG CORBA services: Common Object Services Specification, Update: November 22, 1996. 

[8] The Common Object Request Broker: Architecture and Specification (for specification of valid 

version, see [1]). 

[9] 3GPP TS 32.303: "Telecommunication management; Configuration Management (CM); 

Notification Integration Reference Point (IRP): Common Object Request Broker Architecture 
(CORBA) Solution Set (SS)". 

[10] 3GPP TS 32.312: "Telecommunication management; Generic Integration Reference Point (IRP) 

management; Information Service (IS)". 

[II] 3GPP TS 32.663: "Telecommunication management; Configuration Management (CM); Kernel 
CM Integration Reference Point (IRP): Common Object Request Broker Architecture (CORBA) 
Solution Set (SS)". 
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Definitions and abbreviations 



3.1 Definitions 

For terms and definitions please refer to 3GPP TS 32.101 [1], 3GPP TS 32.102 [2], 3GPP TS 32.600 [3] and 
3GPPTS 32.602 [4]. 

3.2 Abbreviations 

For the purposes of the present document, the following abbreviations apply: 

CORBA Common Object Request Broker Architecture 

DN Distinguished Name 

IS Information Service 

IDL Interface Definition Language (OMG) 

IRP Integration Reference Point 

MO Managed Object 

MOC Managed Object Class 

NRM Network Resource Model 

OMG Object Management Group 

SS Solution Set 



4 IRP document version number string 

The IRP document version number (sometimes called "IRPVersion" or "SS version number") string is used to identify 
this specification. The string is derived using a rule described in 3GPP TS 32.312: [10]. 

This string (or sequence of strings, if more than one version is supported) is returned in getBasicCmlRPVersion 
method. 



Architectural features 



The overall architectural feature of Basic Configuration Management IRP is specified in 3GPP TS 32.602 [4]. 
This clause specifies features that are specific to the CORBA SS. 

5.1 Filter language 

The filter language used in the SS is the Extended Trader Constraint Language (see OMG Notification Service [6]). 
IRP Agents may throw a FilterComplexityLimit exception when a given filter is too complex. However, for 3GPP 
Release 99 an "empty filter" shall be used i.e. a filter that satisfies all MOs of a scoped search (this does not affect the 
filter for notifications as defined in the Notification IRP - see 3GPP TS 32.303 [9]). 

5.2 Syntax for Distinguished Names and Versions 

The format of a Distinguished Name is defined in 3GPP TS 32.300 [5]. 
The version of this IRP is represented as a string (see also clause 4). 
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6 Mapping 

6.1 General mappings 

The IS parameter name managedObjectlnstance is mapped into DN. 

Attributes modelling associations as defined in the NRM (here also called "reference attributes") are in this SS mapped 
to attributes. The names of the reference attributes in the NRM are mapped to the corresponding attribute names in the 
MOC. When the cardinality for an association is 0..1 or 1..1 the datatype for the reference attribute is defined as an 
MOReference. The value of an MO reference contains the distinguished name of the associated MO. When the 
cardinality for an association allows more than one referred MO, the reference attribute will be of type 
MOReferenceSet, which contains a sequence of MO references. 

If a reference attribute is changed, an Attribute ValueChange notification (see TS 32.663 [11]) is emitted. 



6.2 Operation mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of operation visible across the Basic Configuration 
Management IRP. Table 1 indicates mapping of these operations to their equivalents defined in this SS. 

Table 1 : Mapping from IS Operation to SS equivalents 



IS Operation 
(3GPP TS 32.602 [4]) 


SS Method 


Qualifier 


getMoAttributes 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next_basic_cm_informations 


M 


getContainment 


BasicCmlrpOperations::find_managed_objects 
BasicCmlnformationlterator::next_basic_cm_informations 





getlRPVersion (see note) 


get_basic_cm_irp_version 


M 


cancelOperation 


BasicCmlnformationlterator::destroy 





createMo 


BasicCmlrpOperations::create_managed_object 





deleteMo 


BasicCmlrpOperations::delete_managed_objects 

DeleteResultlterator::next_basic_cm_informations 

DeleteResultlterator::next_delete_errors 





setMoAttributes 


BasicCmlrpOperations::modify_managed_objects 
l\/lodifyResultlterator::next_basic_cm_informations 
l\/lodifyResultlterator::next_modification_errors 





getOperationProfile (see 
note) 


get_basic_cm_irp_operation_profile 





getNotificationProfile (see 
note) 


get_basic_cm_irp_notification_profile 





NOTE: This operation is of IOC IVIanagedGenericIRP specified in [10]. The IOC BasicCmIRP of [4] inherits from it. 



6.3 Operation parameter mapping 



The Basic CM IRP: IS (see 3GPP TS 32.602 [4]) defines semantics of parameters carried in operations across the Basic 
Configuration Management IRP. Tables 2 through 8 indicate the mapping of these parameters, as per operation, to their 
equivalents defined in this SS. 

The SS operation find_managed_objects is equivalent to the IS operation getMoAttributes when called with 
ResultContents set to NAMES_AND_ATTRIBUTES. Iterating the BasicCmlnformationlterator is used to fetch the 
result. 
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Table 2: Mapping from IS getMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and 
SearchControl. level) 


M 


filter 


SearchControl search_control (SearchControl.filter) 


M 


attributeListIn 


AttributeNameSet requested_attributes 


M 


managedObjectClass 

managedObjectlnstance 

attributeListOut 


Return value of type BasicCmlnformationlterator - parameter out 
ResuitSet fetched_elements of method next_basic_cm_informations 


M 


status 


Exceptions: 

FindManagedObjects, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedMOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



The SS operation find_managed_objects is equivalent to the IS operation getContainment when called with 
ResultContents set to NAMES. Iterating the BasicCmlnformationlterator is used to fetch the result. 

Table 3: Mapping from IS getContainment parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (No equivalence) 


- 


invokeldentifierOut 


Return value of type BasicCmlnformationlterator 


M 


baseObjectlnstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and SearchControl. level) 





Not specified in IS 


SearchControl search_control (SearchControl.filter) 


M 


containment 


Return value of type BasicCmlnformationlterator - parameter out ResuitSet 
fetched_elements of method next_basic_cm_informations 


M 


status 


Exceptions: 

FindManagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::ParameterNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

ManagedGenericlRPSystem::ValueNotSupported, 

UndefinedMOException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

lllegalFilterFormatException, 

FilterComplexityLimit 


M 



Table 4: Mapping from IS getlRPVersion parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


versionNumberSet 


Return value of type ManagedGenericlRPConstDefs::VersionNumberSet 


M 


status 


Exceptions: 
GetBasicCmlRPVersion 


M 
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Table 5: Mapping from IS cancelOperation parameters to SS equivalents 



IS Operation parameter 


SS IVIethod parameter 


Qualifier 


invokeldentifier 


- (Not applicable, the BasicCmlnformationlterator instance identifies the ongoing 
operation) 


M 


status 


Exceptions: 

ManagedGenericlRPSystem::OperationNotSupported, 

DestroyException 


M 



Table 6: Mapping from IS createMo parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


managedObjectClass 
managedObjectlnstance 


DN object_name 


M 


referenceObjectI nstance 


DN reference_object 





attributeListIn 
attributeListOut 


IVIoAttributeSet attributes 


M 


status 


AttributeErrorSeq attribute_errors 

Exceptions: 

CreateManagedObject, 

IVIanagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::ParameterNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedMOException, 

lllegalDNFormatException, 

DuplicatelVIO, 

CreateNotAI lowed, 

ObjectClasslVlismatch, 

NoSuchObjectClass, 

ParentObjectDoesNotExist 


M 



Table 7: Mapping from IS deleteMo parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


baseObjectI nstance 


DN base_object 


M 


scope 


SearchControl search_control (SearchControl.type and SearchControl. level) 


M 


filter 


SearchControl search_control (SearchControl.filter) 


M 


deletionList 


Return value of type DeleteResultlterator - parameter out ResultSet 
fetched_elements of method next_basic_cm_informations 


M 


status 


Return value of type DeleteResultlterator - parameter out DeleteErrorSeq 

fetched_delete_errors of method next_delete_errors 

Exceptions: 

DeleteManagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedlVloException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopeTypeException, 

lllegalScopeLevelException, 

Illegal FilterFormatException, 

FilterComplexityLimit 


M 
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Table 8: Mapping from IS setMoAttributes parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


baseObjectlnstance 


DN base_object 


IVI 


scope 


SearchControl searcli_control (SearchControl.type and SearchControl. level) 


M 


filter 


SearchControl search_control (SearchControl.filter) 


IVI 


modificationList 


AttributeModificationSet modifications 


M 


modification ListOut 


Return value of type ModifyResultlterator - parameter out ResultSet 
fetclied_elements of method next_basic_cm_informations 


M 


status 


Return value of type ModifyResultlterator - parameter out 

IVIodifyAttributeErrorsSeq fetched_modify_errors of method 

next_modify_errors 

Exceptions: 

IVIodifylVlanagedObjects, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter, 

UndefinedlVloException, 

lllegalDNFormatException, 

UndefinedScopeException, 

lllegalScopelypeException, 

lllegalScopeLevelException, 

Illegal Pi IterFormatException, 

FilterComplexityLimit 


M 



Table 9: Mapping from IS getOperationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


l\/lanagedGenericlRPConstDefs::VersionNumber basic_cm_irp_version 


M 


operationNameProfile, 
operationParameterProfile 


Return value of type ManagedGenericlRPConstDefs::MethodList 


IVI 


status 


Exceptions: 

GetBasicCmlRPOperationProfile, 

ManagedGenericlRPSystem::OperationNotSupported, 

IVIanagedGenericlRPSystem::lnvalidParameter 


M 



Table 10: Mapping from IS getNotificationProfile parameters to SS equivalents 



IS Operation parameter 


SS Method parameter 


Qualifier 


irpVersion 


l\/lanagedGenericlRPConstDefs::VersionNumber 
basic_cm_irp_version 


M 


notificationNameProfile, 
notificationParameterProfile 


Return value of type l\/lanagedGenericlRPConstDefs::MethodList 


IVI 


status 


Exceptions: 

GetBasicCmlRPNotificationProfile, 

ManagedGenericlRPSystem::OperationNotSupported, 

ManagedGenericlRPSystem::lnvalidParameter 


M 



Void 
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Annex A (normative): 
CORBA IDL, Access Protocol 

A.1 IDL specification (file name 
"BasicCMIRPConstDefs.idI") 

//File: BasicCMIRPConstDefs.idI 

#ifndef _BASIC_CM_IRP_CONST_DEFS_IDL_ 
#define _BASIC_CM_IRP_CONST_DEFS_IDL_ 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

/* ## Module: BasicCMIRPConstDef s 

This module contains commonly used definitions for BasicCMIRP. 

*/ 

module BasicCMIRPConstDef s 

{ 

/** 

* Defines the name of a Managed Object Class 
V 

typedef string MOClass; 

/** 

* The format of Distinguished Name (DN) is specified in 3GPP TS 32.300 

* "Name Conventions for Managed Objects". 
V 

typedef string DN; 

/** 

* Defines the name of an attribute of a Managed Object 
*/ 

typedef string MOAttributeName; 

/** 

* Defines the value of an attribute of a Managed Object in form of a CORBA 

* Any. Apart from basic datatypes already defined in CORBA, the allowed 

* attribute value types are defined in the AttributeTypes module. 
*/ 

typedef any MOAttributeValue; 

/** 

* In this version the only allowed filter value is "TRUE" i.e. a filter that 

* matches everything. 
*/ 

typedef string Filter; 

/** 

* ResultContents is used to tell how much information to get back 

* from the f ind_managed_ob jects operation. 

* NAMES: Used to get only Distinguished Name 

* for MOs . 

* The name contains both the MO class 

* and the names of all superior objects in the naming 

* tree. 

* NAMES_AND_ATTRIBUTES: Used to get both NAMES plus 

* MO attributes (all or selected) . 
*/ 

enum ResultContents 
{ 

NAMES, 

NAMES AND ATTRIBUTES 
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* ScopeType defines the kind of scope to use in a search 

* together with SearchControl . level, in a SearchControl value. 

* SearchControl . level is always >= 0. If a level is bigger than the 

* depth of the tree there will be no exceptions thrown. 

* BASE_ONLY ; level ignored, just return the base object. 

* BASE_NTH_LEVEL: return all subordinate objects that are on "level" 

* distance from the base object, where is the base object. 

* BASE_SUBTREE : return the base object and all of its subordinates 

* down to and including the nth level. 

* BASE_ALL ; level ignored, return the base object and all of it's 

* subordinates. 
*/ 

enum ScopeType 
{ 

BASE_ONLY, 

BASE_NTH_LEVEL, 

BASE_SUBTREE, 

BASE_ALL 



/ 



* * 



* SearchControl controls the f ind_managed_ob ject search, 

* and contains ; 

* the type of scope ("type" field), 

* the level of scope ("level" field), level means the "baseOb ject '' 

* level 1 means baseobject including its sub-ordinates etc.. 

* the filter ("filter" field), 

* the result type ("contents" field) . 

* The type, level and contents fields are all mandatory. 

* The filter field contains the filter expression. 

* The string "TRUE" indicates "no filter", 

* i.e. a filter that matches everything. 
*/ 

struct SearchControl 
{ 

ScopeType type; 

unsigned long level; 

Filter filter_; 

ResultContents contents; 



/** 

* Represents an attribute: "name" is the attribute name 

* and "value" is the attribute value. 
*/ 

struct MOAttribute 
{ 

MOAttributeName name; 

MOAttributeValue value; 



typedef sequence <MOAttribute> MOAttributeSet ; 

struct Result 
{ 

DN mo; 

MOAttributeSet attributes; 



typedef sequence <Result> ResultSet; 

/** 

* AttributeErrorCategory defines the categories of errors, related to 

* attributes, that can occur during creation or modification of MOs . 

* NO_SUCH_ATTRIBUTE : The specified attribute does not exist. 

* INVALID_ATTRIBUTE_VALUE : The specified attribute value is not valid. 

* MISSING_ATTRIBUTE_VALUE: An attribute value is required but none was 

* provided and no default value is defined for the attribute. 

* INVALID_MODIFY_OPERATOR: The specified modify operator is not valid 

* (e.g. operator ADD_VALUES applied to a non multi-valued attribute 

* or operator SET_TO_DEFAULT applied where no default value is defined) . 

* MODIFY_NOT_ALLOWED: The modification of the attribute is not allowed. 

* MODIFY_FAILED ; The modification failed because of an unspecified reason. 
*/ 

enum AttributeErrorCategory 
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NO_SUCH_ATTRIBUTE, 

INVALID_ATTRIBUTE_VALUE, 

MISSING_ATTRIBUTE_VALUE, 

INVALID_MODIFY_OPERATOR, 

MODIFY_NOT_ALLOWED, 

MODIFY_FAILED 



* DeleteErrorCategory defines the categories of errors that can occur 

* during deletion of MOs . 

* SUBORDINATE_OBJECT: The MO cannot be deleted due to subordinate MOs. 

* DELETE_NOT_ALLOWED: The deletion of the MO is not allowed. 

* DELETE_FAILED : The deletion failed because of an unspecified reason. 
*/ 

enum DeleteErrorCategory 
( 

SUBORDINATE_OBJECT, 

DELETE_NOT_ALLOWED, 

DELETE_FAILED 



* AttributeError represents an error, related to an attribute, that oc cured 

* during creation or modification of MOs. 

* It contains : 

* - the name of the indicted attribute ("name" field), 

* - the category of the error ("error" field), 

* - optionally, the indicted attribute value ("value" field), 

* - optionally, additional details on the error ("reason" field) . 
*/ 

struct AttributeError 
( 

MOAttributeName name; 

AttributeError Category error; 

MOAttributeValue value; 

string reason; 



typedef sequence <AttributeError> AttributeErrorSeq; 



* DeleteError represents an error that occured during deletion of MOs. 

* It contains : 

* - the distinguished name of the indicted MO ( "ob ject_name" field), 

* - the category of the error ("error" field), 

* - optionally, additional details on the error ( "reason" field) . 

struct DeleteError 
{ 

DN object„name; 

DeleteErrorCategory error; 

string reason; 



typedef sequence <DeleteError> DeleteErrorSeq; 

/** 

* Modif yAttributeErrors represents errors that occured during 

* modification of attributes of a MO. 

* It contains : 

* - the distinguished name of the indicted MO ( "ob ject_name" field), 

* - a sequence containing the attribute errors ("errors" field) . 

struct Modif yAttributeErrors 
( 

DN object_name; 

AttributeErrorSeq errors; 



typedef sequence <Modif yAttributeErrors> Modif yAttributeErrorsSeq; 
typedef sequence <MOAttributeName> AttributeNameSet ; 



/' 



Modif yOperator defines the way in which an attribute value is to be 
applied to an attribute in a modification of MO attributes. 
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* REPLACE; replace the current value with the provided value 

* ADD_VALUES: for a multi-valued attribute, add the provided values to the 

* current list of values 

* REMOVE_VALUE S ; for a multi-valued attribute, remove the provided values 

* from the current list of values 

* SET_TO_DEFAULT : set the attribute to its default value 
*/ 

enum ModifyOperator 
{ 

REPLACE, 

ADD_VALUES, 

REMOVE_VALUES, 

SET_TO_DEFAULT 



* AttributeModif ication defines an attribute value and the way it is to 

* be applied to an attribute in a modification of MO attributes. 

* It contains ; 

* - the name of the attribute to modify ("name" field), 

* - the value to apply to this attribute ("value" field), 

* - the way the attribute value is to be applied to the attribute 

* ("operator" field) . 
*/ 

struct AttributeModif ication 
{ 

MOAttributeName name; 

MOAttributeValue value; 

ModifyOperator operator; 



typedef sequence <AttributeModif ication> AttributeModif icationSet; 



#endif // _BASIC_CM_IRP_CONST_DEFS_IDL_ 
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A.2 IDL specification (file name "BasicCIVIIRPSystem.idI") 

//File: BasicCMIRPSystem. idl 
#ifndef _BASIC_CM_IRP_SYSTEM_IDL_ 
#define _BASIC_CM_IRP_SYSTEM_IDL_ 

#include <ManagedGenericIRPConstDef s . idl> 
# include <ManagedGenericIRP System. idl> 
#include <BasicCMIRPConstDef s . idl> 

// This statement must appear after all include statements 
#pragma prefix "3gppsa5.org" 

mo du 1 e Basic Cm I RP System 
{ 

exception IllegalFilterFormatException ( 
string reason; 

}; 

exception I llegalDNFormat Except ion ( 
string reason; 

}; 

exception IllegalScopeTypeException ( 
string reason; 

}; 

exception II legal ScopeLevelExcept ion ( 
string reason; 

}; 

exception Undef inedMOException ( 
string reason; 

}; 

exception Undef inedScopeExcept ion ( 
string reason; 

}; 

exception FilterComplexityLimit ( 

string reason; 
}; 

exception DuplicateMO (}; 

exception CreateNotAllowed (}; 

exception Ob jectClassMismatch ( } ; 

exception No SuchObject Class ( 

BasicCMIRPConstDefs : :MOClass objectClass; 

}; 

exception ParentOb jectDoesNotExist ( } ; 

* System otherwise fails to complete the operation. System can provide 

* reason to qualify the exception. The semantics carried in reason 

* is outside the scope of this IRP . 

exception NextBasicCmInf ormations ( string reason; }; 

exception NextDeleteErrors ( string reason; }; 

exception NextModifyErrors ( string reason; }; 

exception DestroyException ( string reason; }; 

exception GetBasicCmlRPVersion { string reason; }; 

exception GetBasicCmlRPOperationProf lie ( string reason; }; 

exception GetBasicCmlRPNotif icationProf lie ( string reason; } ; 

exception FindManagedOb jects ( string reason; }; 

exception CreateManagedOb ject ( string reason; }; 

exception DeleteManagedOb jects ( string reason; }; 

exception ModifyManagedOb jects ( string reason; } ; 

/-.^ 

The BasicCmInf ormationlterator is used to iterate through a snapshot of 
Managed Object Information when IRPManager invokes find_managed_ob jects . 
IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
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the iteration procedure before reaching the last iteration. 

interface BasicCmInf ormationlterator 

( 

/** 

This method returns between 1 and "how_many" Managed Object information. 
The IRPAgent may return less than "how_many" items even if there are 
more items to return. "how_many" must be non-zero. Return TRUE if there 
may be more Managed Object information to return. Return FALSE if there 
are no more Managed Object information to be returned. 

If FALSE is returned, the IRPAgent will automatically destroy the 

iterator . 

@parm how_many how many elements to return in the "f etched_elements" out 

parameter. 
@parm f etched_elements the elements. 
@returns A boolean indicating if any elements are returned. 

"f etched_elements " is empty when the BasicCmInf ormationlterator is 

empty . 

boolean next_basic_cm_inf ormations ( 

in unsigned short how_many, 

out BasicCMIRPConstDef s : :ResultSet f etched_elements 
) 
raises ( 

NextBasicCmInf ormations, 

ManagedGenericIRPSystem: : InvalidParameter, 

ManagedGenericIRPSystem: :OperationNotSupported) ; 

This method destroys the iterator. 

V 

void destroy ( ) 

raises ( 

DestroyException, 

ManagedGenericIRPSystem: :OperationNotSupported) ; 

}; // end of BasicCmInf ormationlterator 

The DeleteResult Iterator is used to iterate through the list of deleted MOs 

when IRPManager invokes method "delete_managed_ob jects" . 

IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 

the iteration procedure before reaching the last iteration. 

interface DeleteResult Iterator : BasicCmInf ormationlterator 
( 

Inherited method "next_basic_cm_inf ormations " has the same behaviour as 
for interface BasicCmInf ormationlterator, except that: 

- The Managed Object information returned in parameter 

"f etched_elements " contains only the DNs of the deleted MOs 
(no attributes are returned) . 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator. 

V 

/** 

This method returns between and "how_many" deletion errors. The 
IRPAgent may return less than "how_many" items even if there are more 
items to return. "how_many" must be non-zero. Return TRUE if there are 
more deletion errors to return. Return FALSE if there are no more 
deletion errors to be returned. 

If FALSE is returned and last call to inherited method 

"next_basic_cm_inf ormations " also returned FALSE (i.e. no more Managed 
Object information to be returned) , the IRPAgent will automatically 
destroy the iterator. 

(3parm how_many : how many deletion errors to return in the 

"f etched_delete„errors " out parameter . 
@parm f etched_delete_errors : the deletion errors. 
@returns: a boolean indicating if any deletion errors are returned. 
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boolean next_delete_errors ( 

in unsigned short how_many, 

out BasicCMIRPConstDefs::DeleteErrorSeq f etched_delete_errors 
) 
raises ( 

NextDeleteErrors, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

}; // end of DeleteResult Iterator 

/** 

The ModifyResult Iterator is used to iterate through the list of modified 
MOs when IRPManager invokes method "modif y_managed_ob jects " . 
IRPManager uses it to pace the return of Managed Object Information. 

IRPAgent controls the life-cycle of the iterator. However, a destroy 
operation is provided to handle the case where IRPManager wants to stop 
the iteration procedure before reaching the last iteration. 

interface Modif yResult Iterator : BasicCmInf ormationlterator 
{ 

Inherited method "next_basic_cm_inf ormations " has the same behaviour as 
for interface BasicCmInf ormationlterator, except that: 

- The Managed Object information returned in parameter 

"f etched_elements " contains DNs and attributes of the modified MOs. 

- If FALSE is returned, the IRPAgent will not automatically destroy the 
iterator. 

/** 

This method returns between and "how_many" modification errors. The 
IRPAgent may return less than "how_many" items even if there are more 
items to return. "how_many" must be non-zero. Return TRUE if there are 
more modification errors to return. Return FALSE if there are no more 
modification errors to be returned. 

If FALSE is returned and last call to inherited method 

"next_basic_cm_inf ormations " also returned FALSE (i.e. no more Managed 
Object information to be returned) , the IRPAgent will automatically 
destroy the iterator. 

@parm how_many : how many modification errors to return in the 

"f etched_modif y_errors " out parameter . 
@parm f etched_modif y_errors : the modification errors. 
@returns : a boolean indicating if any modification errors are returned. 

boolean next_modif ication_errors ( 

in unsigned short how_many, 

out BasicCMIRPConstDef s : :ModifyAttributeErrorsSeq 
fetched_modify_errors 
) 
raises ( 

NextModifyErrors, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

}; // end of ModifyResultlterator 

/** 

* The BasicCmlrpOperations interface. 

* Supports a number of Resource Model versions. 
*/ 

interface BasicCmlrpOperations 
{ 

/** 

* Get the version (s) of the interface 

* @raises GetBasicCmlRPVersion when the system for some reason 

* can not return the supported versions. 

* @returns all supported versions. 
*/ 

ManagedGenericIRPConstDef s ; ; Vers lonNumber Set get_basic„cm_irp_version ( ) 
raises (GetBasicCmlRPVersion) ; 

/** 
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* Return the operation profile for a specific Basic CM IRP version. 

* @raises GetBasicCmlRPOperationProf ile when the system for some reason 

* cannot return the supported operations and parameters. 

* @returns the list of all supported operations and their supported 

* parameters for the specified version. 
V 

ManagedGenericIRPConstDef s : :MethodList get_basic_cm_irp_operation_prof ile 
( 

in ManagedGenericIRPConstDef s : : VersionNumber basic_cm_irp_version 
) 
raises ( 

GetBasicCmlRPOperationProf ile, 

ManagedGeneric IRP System: : Ope r at ionNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

/** 

* Return the notification profile for a specific Basic CM IRP version. 

* @raises GetBasicCmlRPNotif icationProf ile when the system for some 

* reason cannot return the supported notifications and parameters. 

* @returns the list of all supported notifications and their supported 

* parameters for the specified version. 
V 

ManagedGenericIRPConstDef s : :MethodList 

get_basic_cm_irp_notif ication_prof ile ( 

in ManagedGenericIRPConstDef s : : VersionNumber basic_cm_irp_version 
) 
raises ( 

GetBasicCmlRPNotif icationProf ile, 

ManagedGenericIRPSystem: : Ope rat ionNot Supported, 

ManagedGenericIRPSystem: : InvalidParameter) ; 

* Performs a containment search, using a SearchControl to 

* control the search and the returned results. 

* All MOs in the scope constitute a set that the filter works on. 

* The result BasicCmInf ormationlterator contains all matched MOs, 

* with the amount of detail specified in the SearchControl. 

* For the special case when no managed objects are matched in 

* f ind_managed_ob jects, the BasicCmInf ormationlterator will be returned. 

* Executing the next_basicCmInf ormations in the 

* BasicCmInf ormationlterator will return FALSE for 

* completion. 

* @parm base^object The start MO in the containment tree. 

* @parm search_control the SearchControl to use. 

* @parm requested_attributes defines which attributes to get. 

* If this parameter is empty (""), all attributes shall 

* be returned. In this version this is the only supported semantics. 

* Note that this argument is only 

* relevant if ResultContents in the search control is 
'^ specif ed to NAMES_AND_ATTRIBUTES . 

* @raises ManagedGenericIRPSystem: :ValueNotSupported if a valid but 

* unsupported parameter value is passed. E.g. the contents 

* field in the searchcontrol parameter contains the value NAMES and 

* the optional getContainment IS operation is not supported. 

* @raises Undef InedMOException The MO does not exist. 

* @raises IllegalDNFormatException The dn syntax string is 

* malformed. 

* @raises IllegalScopeTypeException The ScopeType in scope contains 

* an illegal value. 

* @raises IllegalScopeLevelException The scope level is negative 

* (<0) . 

* @raises IllegalFilterFormatException The filter string is 

* malformed. 

* @raises FilterComplexityLimit if the filter syntax is correct, 

* but the filter is too complex to be processed by the IRP Agent . 

* @see SearchControl 

* @see BasicCmInf ormationlterator 
V 

BasicCmInf ormationlterator find_managed_ob jects ( 

in BasicCMIRPConstDef s : :DN base_object, 

in BasicCMIRPConstDef s : : SearchControl search_control, 

in BasicCMIRPConstDef s : : AttributeNameSet requested_attributes ) 
raises ( 
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FindManagedOb jects, 

ManagedGenericIRP System: : ParameterNot Supported, 



ManagedGenericIRPSystem: : InvalidParameter, 

ManagedGenericIRP System: :ValueNot Supported, 

ManagedGenericIRPSystem: : Ope r at ionNot Supported, 

Undef inedMOException, 

I llegalDNFormat Except ion, 

Undef inedScopeExcept ion, 

II legal ScopeTypeExcept ion, 

II legal ScopeLevelExcept ion, 

IllegalFilterFormatException, 

FilterComplexityLimit ) ; 



* Performs the creation of a MO instance in the MIB maintained 

* by the IRP Agent . 

* @parm object_name: the distinguished name of the MO to create. 

* @parm reference_ob ject : the distinguished name of a reference MO. 

* @parm attributes: in input, initial attribute values for the MO to 

* create; in output, actual attribute values of the created MO. 

* @parm attribute_errors : errors, related to attributes, that caused the 

* creation of the MO to fail. 

* @raises ManagedGenericIRPSystem: :OperationNotSupported: The operation 

* is not supported. 

* @raises ManagedGenericIRPSystem: :ParameterNotSupported: An optional 

* parameter is not supported. 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided. 

* @raises Undef inedMOException: The MO does not exist. 

* @raises IllegalDNFormatException: The DN syntax string is malformed. 

* @raises DuplicateMO: A MO already exist with the same DN as the one 

* to create. 

* @raises CreateNotAllowed: The creation of the MO is not allowed. 

* @raises Ob jectClassMismatch : The object class of the MO to create does 

* not match with the object class of the provided reference MO. 

* @raises NoSuchOb jectClass : The class of the object to create is not 

* recognized. 

* @raises ParentOb jectDoesNotExist : The parent MO instance of the 

* ManagedEntity specified to be created does not exist. 
*/ 

void create_managed_ob ject ( 

in BasicCMIRPConstDef s : :DN object_name, 

in BasicCMIRPConstDef s : :DN ref erence_ob ject , 

inout BasicCMIRPConstDef s : :MOAttributeSet attributes, 

out BasicCMIRPConstDef s : :AttributeErrorSeq attribute_errors 
) 
raises ( 

Great eManagedOb ject, 

ManagedGenericIRPSystem: : OperationNotSupported, 

ManagedGenericIRPSystem: : ParameterNotSupported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

IllegalDNFormatException, 

DuplicateMO, 

CreateNotAllowed, 

Ob jectClassMismatch, 

NoSuchOb jectClass, 

ParentOb JectDoesNotExist ) ; 



I-* 



Performs the deletion of one or more MO instances from the MIB 
maintained by the IRPAgent, using a SearchControl to control the 
instances to be deleted. 

All MOs in the scope constitute a set that the filter works on. 

All matched MOs will be deleted by this operation. 

The returned DeleteResult Iterator is used to retrieve the DNs of the 

MOs deleted and the errors that may have occurred preventing deletion 

of some MOs . 

For the special case when no managed objects are matched in 

delete_managed_ob jects, the DeleteResultlterator will be returned. 

Executing the next_basicCmInf ormations in the DeleteResultlterator 

will return FALSE for completion. 

@parm base_object: the start MO in the containment tree. 

@parm search_control : the SearchControl to use; field "contents" has no 
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* meaning here and shall be ignored. 

* @returns: a DeleteResult Iterator (see above) . 

* @raises ManagedGenericIRPSystem: : OperationNotSupported: The operation 

* is not supported. 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided. 

* @ raises Undef inedMOException : The MO does not exist . 

* @ raises I llegalDNFormat Except ion : The DN syntax string is malformed. 

* @ raises IllegalScopeTypeException : The ScopeType in scope contains 

* an illegal value. 

* @raises IllegalScopeLevelException : The scope level is negative (<0) . 

* ©raises IllegalFilterFormatException : The filter string is malformed. 

* @raises FilterComplexityLimit : The filter syntax is correct, 

* but the filter is too complex to be processed by the IRP Agent . 
V 

DeleteResult Iterator delete_managed_ob jects ( 

in BasicCMIRPConstDef s : :DN base_object, 

in BasicCMIRPConstDef s : : SearchControl search_control 
) 
raises ( 

De let eManagedOb jects, 

ManagedGenericIRPSystem: : OperationNotSupported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

I llegalDNFormat Except ion, 

Undef inedScopeExcept ion, 

IllegalScopeTypeException, 

IllegalScopeLevelException, 

IllegalFilterFormatException, 

FilterComplexityLimit) ; 

* Performs the modification of MO attributes. One or more MOs attributes 

* may be modified according to a SearchControl. 

* All MOs in the scope constitute a set that the filter works on. 

* All matched MOs will have their attributes modified by this operation. 

* The returned ModifyResult Iterator is used to retrieve the DNs of the 

* modified MOs together with the values of the modified attributes, and 

* the errors that may have occurred preventing modification of some 

* attributes . 

* For the special case when no managed objects are matched in 

* modify_managed_ob jects, the ModifyResult Iterator will be returned. 

* Executing the next_basicCmInf ormations in the ModifyResult Iterator 

* will return FALSE for completion. 

* @parm base_object: the start MO in the containment tree. 

* @parm search_control : the SearchControl to use; field "contents" has no 

* meaning here and shall be ignored. 

* @parm modifications: the values for the attributes to modify and 

* the way those values are to be applied to the attributes. 

* @returns: a ModifyResult Iterator (see above) . 

* @raises ManagedGenericIRPSystem: : OperationNotSupported: The operation 

* is not supported 

* @raises ManagedGenericIRPSystem: : InvalidParameter : An invalid 

* parameter value has been provided 

* @raises Undef inedMOException : The MO does not exist. 

* @raises IllegalDNFormatException : The DN syntax string is malformed. 

* @ raises IllegalScopeTypeException: The ScopeType in scope contains 

* an illegal value. 

* @raises IllegalScopeLevelException: The scope level is negative (<0) . 

* @raises IllegalFilterFormatException: The filter string is malformed. 

* @raises FilterComplexityLimit: The filter syntax is correct, 

* but the filter is too complex to be processed by the IRP Agent . 

ModifyResult Iterator modify_managed_ob jects ( 

in BasicCMIRPConstDef s : :DN base_object, 

in BasicCMIRPConstDef s : : SearchControl search_control, 

in BasicCMIRPConstDef s : : AttributeModif icationSet modifications 
) 
raises ( 

Modi f yManagedOb j e ct s , 

ManagedGenericIRPSystem: : OperationNotSupported, 

ManagedGenericIRPSystem: : InvalidParameter, 

Undef inedMOException, 

IllegalDNFormatException, 
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Undef inedScopeException, 
II legal ScopeTypeExcept ion, 
II legal ScopeLevelExcept ion, 
IllegalFilterFormatException, 
FilterComplexityLimit ) ; 



#endif // _BASIC_CM_IRP_SYSTEM_IDL_ 
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